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CLAIMS 

1 . (Currently Amended) A method of shifting a first operand, the method comprising 
the steps of: 

for each byt o of the first op e rand, configuring a data input Hne for each bit of each byte of 
the first operand a data input Hn e, each data input line comprising a first part and a second part, 
corresponding to successive shift amounts, wherein the first part of the data input line corresponds 
to a shift in a first direction and the second part of the data input Ime corresponds to a shift in a 
second direction; and 

selecting fi-om the data input line for each bit the bit corresponding to the value of the shift 
amount and shift direction, wherein the shift direction is used to select a bit from the first part or the 
second part. 

2. (Original) The method of Claim 1, wherein the operand is at least one of a 16-bit 
operand, a 32-bit operand, a 64-bit operand, 128-bit operand, a 256-bit operand, and a 512-bit 
operand. 

3. (Original) The method of Claim 1, wherein at least one of the first part and the 
second comprises zeros to fill vacated bits with a zero. 

4. (Original) A method of shifting a first operand, the method comprising the steps 

of: 

extracting from an instruction a direction to shift the first operand; 

extracting from a second operand an amount to shift the first operand; 

configuring a data input line for each bit of each byte of the first operand, each data input 
line comprising a first part and a second part, wherein the first part comprises bits ordered 
corresponding to shift amounts in a first direction and the second part comprises bits ordered 
corresponding to shift amounts in a second direction; and 

selecting from each data input line tiie bit corresponding to the value of the shift amount and 
shift direction, wherein the shift direction is used to select a bit from the first part or the second part. 
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5. (Original) The method of Claim 4, wherein at least one of the first part and the 
second part comprises zeros to fill vacated bits with a zero. 

6. (Original) The method of Claim 4, wherein the second operand is set to zero to 
provide the second part of the data input lines. 

7. (Original) A method of performing vector permute operations, the method 
comprising the steps of: 

receiving an instruction for a vector permute operation; 

decoding the instruction to determine an instruction type, a first operand, and a second 
operand; 

selecting fi-om one or more resources the first operand; 

selecting fi'om one or more resources the second operand; 

extracting fi-om the instruction a direction to shift the first operand; 

extracting from the second operand an amount to shift the first operand; 

configuring a third operand to comprise the direction and the amount in one or more bytes; 

performing a second fiinction on the first operand and the second operand according to the 
values in the third operand; 

performing a shifter function on the first operand and the second operand according to the 
values in the third operand; 

determining whether the instruction type corresponds to the second fiinction or to the shifter 
fiinction; 

upon a determination that the instruction type corresponds to the second fimction, setting the 
result of the vector permute operation to the output of tiie second function; and 

upon a determination that the instruction type corresponds to the shifter fimction, setting the 
result of the vector permute operation to the output of the shifter fiinction. 

8. (Currently Amended) The method of Claim 7, wherein at least one of the a^first 
part and (he a^second part of data input lines comprises zeros to fill vacated bits with a zero. 
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9. (Original) The method of Claim 7, wherein the second function is a CROSSBAR 
function. 

10. (Currently Amended) The method of Claim 7, wherein the second operand is set 
to zero to provide the a second part of the-data input lines. 

1 1 . (Original) An apparatus for shifting a first operand, the apparatus comprising: 
means for configuring for each bit of each byte of the first operand a data input line, 

comprising a first part and a second part, corresponding to successive shift amounts, wherein the 
first part of the data input line corresponds to a shift in a first direction and the second part of the 
data input line corresponds to a shift in a second direction; and 

means for selecting fi-om the data input line for each bit the bit corresponding to the value of 
the shift amount and shift direction, wherein the shift direction is used to select a bit fi"om the first 
part or the second part. 

12. (Original) The apparatus of Claim 11, wherein the operand is at least one of a 16- 
bit operand, a 32-bit operand, a 64-bit operand, 128-bit operand, a 256-bit operand, and a 512- 
bit operand. 

13. (Original) The apparatus of Claim 11, wherein at least one of the first part and the 
second part comprises zeros to fill vacated bits with a zero. 

14. (Original) An apparatus for shifting a first operand, the apparatus comprising: 
means for extracting from an instruction a direction to shift the first operand; 

means for extracting from a second operand an amount to shift the first operand; 

means for configuring a data input line for each bit of each byte of the first operand, each 
data input line comprising a first part and a second part, wherein the first part comprises bits ordered 
corresponding to shift amounts in a first direction and the second part comprises bits ordered 
corresponding to shift amounts in a second direction; and 
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means for selecting from each data input line the bit corresponding to the value of the shift 
amount and shift direction, wherein the shift direction is used to select a bit from the first part or the 
second part. 

15. (Original) The apparatus of Claim 14, wherein at least one of the first part and the 
second part comprises zeros to fill vacated bits with a zero. 

16. (Original) The apparatus of Claim 14, wherein the second operand is set to zero to 
provide the second part of the data input lines. 

17. (Original) An apparatus for performing vector permute operations, the apparatus 
comprising: 

means for receiving an instruction for a vector permute operation; 

means for decoding the instruction to determine an instruction type, a first operand, and a 
second operand; 

means for selecting from one or more resources the first operand; 
means for selecting from one or more resources the second operand; 
means for extracting from the instruction a direction to shift the first operand; 
means for extracting from the second operand an amount to shift the first operand; 
means for configuring a third operand to comprise the direction and the amount in one or 
more bytes; 

means for performing a second fiinction on the first operand and the second operand 
according to the values in the third operand; 

means for performing a shifter fiinction on the first operand and the second operand 
according to the values in the third operand; 

means for determining whether the instruction type corresponds to the second fimction or to 
the shifter ftmction; 

means for, upon a determination that the instruction type corresponds to the second function, 
setting the result of the vector permute operation to the output of the second fimction; and 

means for, upon a determination that the instruction type corresponds to the shifter fimction, 
setting the result of the vector permute operation to the output of the shifter fimction. 
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18. (Currently Amended) The apparatus of Claim 17, whoroin further comprising at 
least one of *e a^first part and the a_second part of data inout lines comprises zeros to fill 
vacated bits with a zero. 

19. (Original) The apparatus of Claim 17, wherein the second function is a 
CROSSBAR function. 

20. (Currently Amended) The apparatus of Claim 17, wherein further comprising t he 
second operand is set to zero to provide the a second part of the data input lines. 

21. (Original) A computer program product for shifting a first operand, the computer 
program product having a medium with a computer program embodied thereon, the computer 
program comprising: 

computer program code for configuring for each bit of each byte of the first operand a data 
input line, comprising a first part and a second part, corresponding to successive shift amounts, 
wherein the first part of the data input line corresponds to a shift in a first direction and the second 
part of the data input line corresponds to a shift in a second direction; and 

computer program code for selecting from the data input line for each bit the bit 
corresponding to the value of the shift amount and shift direction, wherein the shift direction is used 
to select a bit from the first part or the second part. 

22. (Original) The computer program product of Claim 21, wherein the operand is at 
least one of a 16-bit operand, a 32-bit operand, a 64-bit operand, 128-bit operand, a 256-bit 
operand, and a 512-bit operand. 

23. (Original) The computer program product of Claim 21, wherein at least one of the 
first part and the second part comprises zeros to fill vacated bits with a zero. 

24. (Original) A computer program product for shifting a first operand, the computer 
program product having a medium with a computer program embodied thereon, the computer 
program comprising: 
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computer program code for extracting from an instruction a direction to shift the first 
operand; 

computer program code for extracting from a second operand an amount to shift the first 
operand; 

computer program code for configuring a data input line for each bit of each byte of the first 
operand, each data input line comprising a first part and a second part, wherein the first part 
comprises bits ordered corresponding to shift amounts in a first direction and the second part 
comprises bits ordered corresponding to shift amounts in a second direction; and 

computer program code for selecting from each data input line the bit corresponding to the 
value of the shift amount and shift direction, wherein the shift direction is used to select a bit from 
the first part or the second part. 

25. (Original) The computer program product of Claim 24, wherein at least one of the 
first part and the second part comprises zeros to fill vacated bits with a zero. 

26. (Original) The computer program product of Claim 24, wherein the second 
operand is set to zero to provide the second part of the data input lines. 

27. (Original) A computer program product for performing vector permute 
operations, the computer program product having a medium with a computer program embodied 
thereon, the computer program comprising: 

computer program code for receiving an instruction for a vector permute operation; 

computer program code for decoding the instruction to determine an instruction type, a first 
operand, and a second operand; 

computer program code for selecting from one or more resources the first operand; 

computer program code for selecting from one or more resources the second operand; 

computer program code for extracting from the instruction a direction to shift the first 
operand; 

computer program code for extracting from the second operand an amount to shift the first 
operand; 
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computer program code for configuring a third operand to comprise the direction and the 
amount in one or more bytes; 

computer program code for performing a second function on the first operand and the 
second operand according to the values in the third operand; 

computer program code for performing a shifter function on the first operand and the second 
operand according to the values in the third operand; 

computer program code for determining whether the instruction type corresponds to the 
second function or to the shifter function; 

computer program code for, upon a determination that the instruction type corresponds to 
the second function, setting the resuft of the vector permute operation to the output of the second 
function; and 

computer program code for, upon a determination that the instruction type corresponds to 
the shifter function, setting the result of the vector permute operation to the output of the shifter 
function. 

28. (Original) The computer program product of Claim 27, wherein at least one of the 
first part and the second comprises zeros to fill vacated bits with a zero. 

29. (Original) The computer program product of Claim 27, wherein the second 
fimction is a CROSSBAR fiincfion. 

30. (Original) The computer program product of Claim 27, wherein the second 
operand is set to zero to provide the second part of the data input lines. 
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